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[57] ABSTRACT 

A digital joystock is interfaced to a video game by 
utilizing diodes for isolation and providing means for 
strobing the digital joystick. In this manner, the number 
of conductors required in the cable coupling the digital 
joystick to the video game circuitry is significantly 
reduced. In one embodiment, a matrix-type keyboard is 
included in the remote control unit without adding a 
significant number of additional conductors. Further¬ 
more, the multiplexer ordinarily required to couple the 
conductors from the digital joystick and the matrix 
keyboard is eliminated by this technique. 

8 Claims, 25 Drawing Figures 
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Fig, 6 
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DIGITAL JOYSTICK CONTROL INTERFACE 

SYSTEM FOR VIDEO GAMES AND THE LIKE 

BACKGROUND OF THE INVENTION 

This invention relates to manually-operated digital 
controls, and more particularly to a digital joystick 
control interface system. 

This invention further relates to copending patent 
application Ser. No. 785,006 by Kastner et al., entitled 10 
System for Displaying Character and Graphic Informa¬ 
tion on a Color Video Display; Ser. No. 785,144 by 
Burson et al., entitled Digital Joystick Control; and Ser. 

No. 785,143 by Burson, entitled System to Control Ve¬ 
locity Vector of a Display Cursor, each filed of even 15 
date with and assigned to the assignee of the present 
invention. This invention also relates to Ser. No. 
791,913, filed Apr. 28, 1977, by Trenkler et al., entitled 
Video Game With Portable Control Units. 

In order to interface a digital joystick having, for 20 
example, four bits of resolution per axis, would nor¬ 
mally require eight lines for data output plus one com¬ 
mon input line. If the digital joystick were to be incor¬ 
porated in a remote unit, a 9-conductor cable would be 
required to connect the remote unit to the main console 25 
containing, for example, video game circuitry. If, in 
addition to the digital joystick, a 20-key matrix key¬ 
board were to be included in the remote unit, the num¬ 
ber of conductors required in the cable would be in¬ 
creased to 18 (the 9 lines for the joystick plus 5 input 30 
scan lines and 4 output lines from the keyboard). Also, 
in order to interface the twelve data output lines to a 
4-bit data bus, would require a multiplexer. 

It is therefore an object of the present invention to ' 
provide a digital control interface to a system which 35 * 
reduces the number of conductors required to couple 
the digital control to the controlled circuitry of the 1 
system. 

It is another object of the invention to provide an 1 
improved interface between a remote digital control 40 
unit and the controlled circuitry located in some other s 
unit of the system. \ 

It is a further object of the invention to provide an 
improved interface between a remote control unit hav- c 
mg a manually-operated digital joystick and key matrix 45 
keyboard and the controlled circuitry located in some c 
other unit of the system. 

It is yet another object of the invention to provide an 3 
improved video game having a digital joystick. 

Still another object of the invention is to provide an 50 tl 
improved interface between a manually-controlled digi- F 
tal joystick and a video game. 

A still further object of the invention is to provide a F 
video game system with an improved interface between 
a pair of remote units each including a digital joystick 55 ci 
and key matrix keyboard and the main circuitry of the sj 

video game located in a central unit with a reduced F 

number of conductors in the cables therebetween. 

Yet another object of the invention is to provide a li; 
system with a remote control unit having a digital joy- 60 
stick and key matrix keyboard which unit is coupled to cl 
a data bus without the requirement of a multiplexer. oi 


input conductor is provided for each axis in the present 
embodiment. In one embodiment, a key matrix key¬ 
board is included in a remote control unit with the 
digital joystick; both the joystick and keyboard provide 
an output to a common data bus without the require¬ 
ment of a multiplexer. Diode isolation is provided be¬ 
tween the data output conductors of the digital joystick 
and the data output conductors of the keyboard. The 
input conductors of the keyboard are scanned along 
with the joystick. In one system embodying the inven¬ 
tion, pull-up resistors are connected to the output data 
bus in the main unit. When the keyboard scan lines and 
digital joystick scan lines are high, all the lines to the 
data bus are high. When one of the joystick scan lines is 
low and the other scan lines are high, the digital joy- 
stick switch contacts, which are making contact with 
the scan line, will pull the corresponding data lines low, 
the other data lines will remain high. Therefore, the 
joystick position is read out to the data bus. 

For example, a digital joystick control having four 
bits of resolution per axis (x and y) and a twenty-key 
matrix keyboard are included in a hand-held remote 
control unit for a video game. In accordance with the 
present invention, eleven conductors rather than the 
eighteen conductors normally required (9 for the digital 
joystick and 9 for the keyboard) interface the remote 
control unit to a 4-bit data bus without the requirement 
of a multiplexer. 


BRIEF DESCRIPTION OF THE INVENTION 

These and other objects are accomplished in accor- 65 
dance with the present invention by providing diode 
isolation between the data output conductors of the 
digital joystick and scanning the input conductors. One 


0 BRIEF DESCRIPTION OF THE DRAWINGS 

Still further objects and advantages of the invention 
will be apparent from the detailed description and 
claims when read in conjunction with the accompany- 
5 mg drawings wherein: 

FIG. 1 is a perspective view of a video game system 
embodying the present invention; 

FIGS. 2a and 2b comprise a block diagram of the 
video game system of FIG. 1; 
j FIG. 3 a is a perspective view of a novel digital joy¬ 

stick control utilized in the video game system of FIG. 

FIG. 3 b is a side elevational view of the joystick 
control of FIG. 3a; 

FIG. 3c is a front elevational view of the joystick 
control of FIG. 3a; 

FIG. 3c? is a top view of the joystick control of FIG 
3a; 

FIG. 4a is a graphic representation of the coding of 

l7r e ^ ar , CUate P lates utilized in the joystick control of 
rlG. 3 a; 

™ G - is a circuit diagram of the digital joystick of 
rlG. 3a, keyboard, and novel interface circuit; 

FIG. 5 is a circuit diagram of the data multiplex cir¬ 
cuit coupling the remote control units of the video game 
system to the main module of the video game system of 
rlG. 1; 

FKL 6 is a block diagram of the microcomputer uti¬ 
lized to control the video game system of FIG. 1; 

FIGS. 7a and lb comprise a circuit diagram of the 
character table memory and character generator mem- 
ory; 

“ a circuit diagram of the display memory; 
rlGb. 9a and 9b comprise a circuit diagram of the 
composite video generator; 

is a c j rcuit diagram of the timing oscillator; 
MUb. lla and 116 comprise a circuit diagram of the 
memory timing circuit; 
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FIG. 12 is a circuit diagram of the horizontal sync 
timing circuit; 

FIG. 13 is a circuit diagram of the vertical counter 
and sync timing circuits, and a circuit diagram of the 
composite blanking and sync circuits; 5 

FIG. 14 is a circuit diagram of the background color 
generator; 

FIG. 15a is a graphic representation of the display 
matrix; 

FIG. 156 is a graphic representation of the character 10 
matrix including exemplary characters; and 

FIG. 15c is a graphic representation of the novel 
inter-memory addressing technique of the display, char¬ 
acter table and character generator memories. 

VIDEO GAME SYSTEM 

A video game system embodying the present inven¬ 
tion is illustrated in FIG. 1. Referring to FIG. 1, the 
video game system is comprised of a main module 11 
which is coupled to the antenna terminal of television 20 
set 10 and one or more remote control units 12a, 126 
which are coupled to the main module 11 by means of 
cables or the like. In the present embodiment, each of 
the remote control units 12a, 126 include a joystick 
control 13a, 136 and a keyboard 14a, 146. Operation of 25 
the joystick 13a, 136 and/or keyboard 14a, 146 deter¬ 
mines the play of the game. Games are selected by 
plugging a selected module 87 into a module receiving 
socket 88. The present video game system is controlled 
by a microprocessor or microcomputer, the operation 30 
of which is determined by a stored program, different 
stored programs being utilized for each game or set of 
games. In one embodiment, the microprocessor is con¬ 
tained within the module 11 and a read-only memory 
containing a particular stored program for a particular 35 
game or set of games contained within module 87. In 
another embodiment, a microcomputer, which is a com¬ 
plete processor including a stored program ROM fabri¬ 
cated on a single semiconductor chip, is contained 
within the cartridge 87. Slots 90 may be provided in the 40 
main module 11 for storage of additional cartridges 89 
each containing different stored programs for control of 
different games. 

As previously mentioned, the plug-in cartridge may 
contain either a ROM or a complete microcomputer. 45 
For purpose of convenience, the latter embodiment will 
herein be described in detail, noting that the former 
system is electrically equivalent, the only difference 
being that in the former system, the stored program 
memory is contained in the plug-in unit, and the remain- 50 
der of the described circuitry is contained in separate 
semiconductor chips within the module 11. 

Referring then to FIGS. 2a and 26, a block diagram 
of a video game system embodying the present inven¬ 
tion is shown. As illustrated in FIGS. 1 and 2a, each of 55 
the remote control units 12a, 126 are coupled to the 
main video game module 11 by means of an 11-conduc¬ 
tor cable. The digital joystick control and remote con¬ 
trol interface which are inventive features of the video 
game system will next be described in detail with re- 60 
spect to FIGS. 3 a-3d, 4a and 46. 

DIGITAL JOYSTICK 

Referring to FIGS. 3 a-3d, each digital joystick con¬ 
trol 13a, 136 is comprised of a platform 201 having a 65 
centrally-located circular opening provided therein. A 
base member 202 having respective pairs of side support 
members such as side walls 205 and 206 and end support 
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members such as end walls 203 and 204 define a cham¬ 
ber in registration with the circular opening in platform 
201 from which base member 202 depends. The joy¬ 
stick, which is manually controlled by the player, in¬ 
cludes an elongated shaft 207 having a spherical ball 208 
on one end thereof. Elongated shaft 207 is disposed 
outwardly of platform 201 with spherical ball 208 being 
partially received within the chamber formed by base 
member 202 and protruding outwardly of the circular 
opening in platform 201. First and second socket mem¬ 
bers 209 and 210 are mounted within the chamber 
formed by base member 202. Socket member 209 is 
cup-shaped so that spherical ball 208 is seated there 
within. Cup-shaped member 209 has an elongated slot 
200 disposed substantially perpendicular to side walls 
205 and 206 of base member 202, and is pivotally con¬ 
nected to side walls 205 and 206 by means of axle mem¬ 
ber 218 for movement about an axis perpendicular to 
side walls 205 and 206. Socket member 210 comprises 
an arcuate strap extending about cup-shaped member 

209 in traverse relationship thereto. Arcuate strap 210 
has an elongated groove 212 disposed substantially per¬ 
pendicular to end walls 203 and 204, and is pivotally 
connected to end walls 203 and 204 by means of axle 
member 219 for movement about an axis perpendicular 
to end walls 203 and 204. Spherical ball 208 includes pin 
member 211 extending through slot 200 in socket mem¬ 
ber 209 and into groove 212 in socket member 210 
thereby interconnecting socket members 209 and 210 
with the joystick to provide a swivel joint between ball 
208 and socket members 209 and 210 enabling move¬ 
ment of shaft 207 about ball 208 in any direction with 
respect to platform 201. Circuit board 213 is mounted in 
spaced parallel relation to end wall 203, and circuit 
board 214 is mounted in spaced parallel relation to side 
wall 205. A plurality of wiper arms 223 and 222 extend 
outwardly of circuit boards 213 and 214, respectively. 
Arcuate plates 215 and 216, comprised of a conductive 
material, are fixably connected to the socket members 

210 and 209, respectively, for movement therewith. 
Arcuate plate 215 is mounted exteriorly with respect to 
end wall 203, and is associated with circuit board 213; 
arcuate plate 216 is mounted exteriorly with respect to 
end wall 205, and is associated with circuit board 214. 
Conductive plates 215 and 216 each have a patterned 
surface presenting conductive and non-conductive re¬ 
gions in opposing relation to wiper arms 223 and 222, 
respectively. In the present embodiment, conductive 
plates 215 and 216 are coded so that a “GRAY” code 
representation of the X-Y position of shaft 207 is gener¬ 
ated by wiper arms 222 and 223; the “GRAY” code is 
transmitted from wiper arms 222 and 223 to main mod¬ 
ule 11 of the video game system whereby conduct of the 
game is altered. 

Each joystick 207 is normally in the upright position, 
and maintained in such position by spring members 221 
and 225 which respectively bias members 220 and 224. 
Member 220 is connected to socket member 209 by 
means of axle 218 and member 224 is connected to 
socket member 210 by means of axle member 219. As 
the joystick 207 is moved from the upright position, 
spring members 221 and 225 apply a biasing pressure to 
joystick 207 through members 220 and 224, respec¬ 
tively, thereby making the maneuverability of the joy¬ 
stick 207 less sensitive and more accurately controlla¬ 
ble. 

The electrical operation of joystick controls 13a and 
136 and the interface circuitry between joystick con- 
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trols 13 a and 136, keyboards 14 a and 146 and mi¬ 
crocomputer 15 which is plugged into main module 11 
is best understood with reference to FIGS. 4 a and 46. 

Referring then to FIG. 4a, the conductive and non- 
conductive portions of one of the arcuate plates 215,216 5 
of one of the joystick controls 12 a, 126 is shown in 
rectangular form for easier understanding. In the pres¬ 
ent embodiment, all of the arcuate plates have the same 
pattern. Each set of wiper arms 222, 223 is comprised of 
five independent wiper arms; four receiving wiper arms 10 
L 1 -L 4 and a common wiper arm L c- A voltage applied 
to common wiper arm Lcis transmitted via the conduc¬ 
tive portions of the respective plate 215, 216 and re¬ 
ceived by selected ones of wiper arms L 1 -L 4 to thereby 
generate a “GRAY” coded signal indicative of the posi- 15 
tion of the joystick along the respective (X or Y) axis. 
The combined coded signals from both sets of wiper 
arms 222 and 223 provide microcomputer 15 with the 
complete X-Y position of the joystick 207. 

The data output signals generated by switches 237 20 
and 238 are interfaced to four lines 243-246 comprising 
a common data bus by utilizing diodes 240 and 241 for 
isolation and providing means for independently strob¬ 
ing L c terminals 230 and 231 to separately read the 
digital joystick X axis position, and the digital joystick 25 
Y axis position on the four lines 243-246 of the data bus. 

In the present embodiment, a 20-key keyboard 14a, 146 
is also provided in each remote control unit 12 a, 126, as 
previously mentioned with respect to FIG. 1. The key¬ 
board 14a, 146 is represented electrically in FIG. 46 by 30 
matrix 239. Terminals 230-236 are coupled to respec¬ 
tive ones of digit terminals (D 0 -D 12 ) 18 of microcom¬ 
puter 15 (which is illustrated in detail in FIG. 6 ). Key¬ 
board terminals 232-236 are strobed in strobing se¬ 
quence with joystick terminals 230 and 231, and a 4-bit 35 
code indicative of an activated key in matrix 239 is 
thereby read out of the four lines 243-246 of the data 
bus at a predetermined time in the strobing sequence. 
Diodes 242 are provided to isolate the keyboard outputs 
from the joystick outputs to lines 243-246 of the data 40 
bus. 

As illustrated in FIG. 2a, the four lines 243-246 com¬ 
prising the data bus of each of remote control unit 12 a, 

126 are connected to data multiplexer 100 which pro¬ 
vides for the separate sampling of data from each of the 45 
joystick control unit data busses input on terminals 
1K1-1K4 and 2K1-2K4, the data lines M0-M3 from 
RAM 120 which data is stored in multiplexer register 
121, or the data lines VI, V2, H7, H 8 which are random 
number data derived from vertical counter 137 and 50 
horizontal counter 135. In the present embodiment, data 
multiplexer 100 is comprised of a pair of SN54/74LS253 
integrated selector circuits as illustrated in FIG. 5; reg¬ 
ister 121 is an SN54/74LS174 integrated register cir¬ 
cuit. 55 

The interface which couples the four lines of each 
remote control unit data bus and multiplexer 100 , in the 
present embodiment, includes pull-up resistors 101 
which are connected, in main unit 11 , to each data bus 
lines. When the keyboard scan lines 232-236 and digital 60 
joystick scan lines 230 and 231 are “high”, all of the data 
bus lines 243-246 are “high”. When one of the digital 
joystick scan lines 230 or 231 is “low” and the other 
scan lines are “high”, those of the digital joystick switch 
contacts 237 or 238 which are making contact with the 65 
scanned “low” scan line 230 or 231 will pull the corre¬ 
sponding ones of data bus lines 243-246 “low”; the 
other data lines remain in the “high” “pulled up” condi- 
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tion. In this manner, the relative X and Y positions of 
each joystick 13a, 136 is read out in scanned sequence to 
the respective data bus and the data busses are multi¬ 
plexed along with the outputs of register 121 and to 
counters 135 and 137 provide four bits of data to key¬ 
board inputs 16 (Kl, K2, K4, K 8 ) of microcomputer 15 
which will later be described in detail with respect to 
FIG. 6 . 

As seen from the above-described embodiment, the 
remote control units 12 a, and 126, each having a digital 
joystick control 13a, 136 with four bits of resolution per 
axis (X and Y) and a 20-key matrix keyboard 14a, 146, 
and the microcomputer 15 which is located (after being 
plugged in) in main unit 11 , are interfaced by a total of 
eleven lines (seven scan lines 230-236 and the four data 
lines 243-246) rather than the 18 conductors normally 
required (9 for the digital joystick and 9 for the key¬ 
board) without the need for a multiplexer circuit con¬ 
nected in the remote control unit 12 a, 126. 

Referring again to FIGS. 2a and 26 and to FIG. 6 , the 
four data output lines (Kl, K2, K4, K 8 ) from multi¬ 
plexer 100 are connected to the keyboard input termi¬ 
nals 16 of microprocessor 15 to provide to microproces¬ 
sor 15 joystick positional information and keyboard 
information from remote control units 12 a and 126, 
memory information from RAM 120 which has been 
stored in register 121 or a random number provided by 
horizontal and vertical counters 135 and 137. Digit 
terminals (D 0 -D 12 ) 18 provide scanning signals to scan 
the joystick and keyboard scan lines 230-236 of both 
remote control units 12 a and 126, simultaneously; the 
information is read from a particular one of joystick 
controls 12 a or 126 by the state of data multiplexer 100 
which is controlled by microcomputer 15. Microcom¬ 
puter 15, which is, as previously described, contained in 
plug-in unit 87, includes a ROM 24 for storage of a 
game-generating/controlling program, the game¬ 
generating/controlling program causing microcom¬ 
puter 15 to operate in a particular manner in accordance 
with the data sampled at keyboard input terminals 16 to 
control television set 10 to provide a particular set of 
game images on the display screen thereof. Output data 
from microcomputer 15 is provided at digit terminals 
(D 0 -D 12 ) 18 and segment terminals (Sj—Sg) 17. 

In order to better understand the operation of the 
video game system, the TMS 1100 microcomputer uti¬ 
lized in the present embodiment, will next be described. 

MICROCOMPUTER 15 

A block diagram of the microcomputer (TMS 
1000/1100) 15, which is shown in FIG. 6 , will next be 
described. For a more complete description of the mi¬ 
crocomputer circuit, reference may be made to U.S. 
Pat. No. 3,988,604 for an ELECTRONIC CALCULA¬ 
TOR OR DIGITAL PROCESSOR CHIP HAVING 
MULTIPLE FUNCTION ARITHMETIC UNIT 
OUTPUT, said patent being assigned to the assignee of 
the present invention. Microcomputer system 15 is cen¬ 
tered around a ROM (read-only-memory) 24 and a 
RAM (random-access-memory) 25. The ROM 24 con¬ 
tains 1024 instruction words of eight bits per word, and 
is used to store the program which operates the system. 
The RAM 25 contains 256 memory cells software orga¬ 
nized as four 16-digit groups with four bits per digit. 
Data entered by the joystick or keyboard is stored in 
RAM 25, along with intermediate and final results of 
calculations, as well as status information or “flags,” 
decimal point position and other working data. The 
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RAM functions as the working registers of the mi¬ 
crocomputer system, although it is not organized in a 
hardware sense as separate registers as would be true if 
shift registers or the like were used for this purpose. The 
RAM is addressed by a word address on lines 26, i.e., 5 
one out of sixteen word lines in the RAM is selected, by 
means of a combined ROM and RAM word address 
decode circuit 27. One of four “pages” of the RAM is 
selected by an address signal on two lines 28 applied to 
a RAM page address decoder 29 in the RAM. For a 10 
given word address on lines 26 and page address on 
lines 28, four specific bits are accessed and read out on 
RAM I/O lines 30, via input/output circuit 31, to RAM 
read lines 32. Alternatively, data is written into the 
RAM 25 via the input/output circuitry 31 and the lines 15 
30. The same sixteen line 26 used as RAM word address 
are also used to generate the joystick and keyboard scan 
on the lines 18; to this end the lines 26 pass through the 
RAM 25 and are connected to output registers and 
buffers as will be explained. 20 

The ROM 24 produces an eight-bit instruction word 
on ROM output lines 33 (the bits of the instruction 
word being labeled RO-R7) during each instruction 
cycle. The instruction is selected from 8192 bit locations 
in the ROM, organized into 1024 words containing 25 
eight bits each. The words are divided into 16 groups or 
pages of 64 words each. To address an instruction in the 
ROM requires a one-of-sixty-four ROM word address 
on lines 34 and a one-of-sixteen ROM page address on 
lines 35. The ROM word address on lines 34 is gener- 30 
ated in the same decoder 27 as used to generate the 
RAM word address on lines 26. The ROM word ad¬ 
dress is a six-bit address produced in a program counter 
36 which is a six-stage shift register that may be updated 
after an instruction cycle or may have a six-bit address 35 
loaded into it via lines 37 from ROM output lines 33 for 
a call or branch operation. The RAM and ROM word 
address decoder 27 receives a six-bit encoded address 
on lines 38 from decode data select unit 39 which has 
two inputs. The unit 39 receives a four-bit address from 40 
RAM Y register 40 via lines 41, or it receives a six-bit 
address from the program counter 36 via lines 42, dur¬ 
ing each instruction cycle. A six-bit subroutine register 
43 is associated with the program counter 36 to serve as 
temporary storage for the return word address during 45 
subroutine operations. A six-bit address is stored in the 
register 43, via lines 44 when a call instruction is initi¬ 
ated so that this same address may be loaded back into 
the program counter 36 via lines 45 when execution of 
the subroutine which begins at the call location has been 50 
completed; this conserves instruction words and makes 
programming more flexible. The ROM page address on 
lines 35 is generated in a page address register 46 which 
also has a buffer register 47 associated with it for sub¬ 
routine purposes. The register 46 will always contain 55 
the current page address for the ROM, and directly 
accesses the ROM page decoder. The buffer register 47 
is a multifunction buffer and temporary storage register, 
the contents of which can be the present ROM page 
address, an alternate ROM page address, or the return 60 
page address during subroutine operations. The pro¬ 
gram counter, subroutine register and ROM page ad¬ 
dressing are all controlled by control circuitry 48 which 
receives inputs from the ROM output lines 33 via lines 
49. The control circuitry 48 determines whether branch 65 
and call on “status” or subroutine operations are per¬ 
formed, causes loading of an instruction word into the 
program counter and/or page address register, controls 
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transfer of bits to the subroutine or buffer registers and 
back, controls updating of the program counter, etc. 

Numerical data and other information is operated 
upon in the system by a binary adder 50 which is bitpar- 
allel adder having a precharged carry circuit, operating 
in binary with software BCD correction. The input to 
the adder 50 is determined by an input selector 51 which 
receives four-bit parallel inputs from several sources 
and selects from these what inputs are applied to the 
adder. First, the memory read or recall lines 32 from the 
RAM 25 provide one of the alternatives. Two registers 
receive the adder output, these being the “RAM Y” 
register 40 and an accumulator 52, and each of these has 
output lines separately connected as inputs 53 and 54 of 
the selector 51. A fourth input 55 receives an output 
from “CKB” logic as will be explained. Thus, the adder 
input is selected from the following sources: data mem¬ 
ory or RAM 25 on lines 32; accumulator 52 via lines 53; 
RAM Y register 40 via lines 54; constant, keyboard or 
“bit” information from CKB logic 56 on lines 55. Posi¬ 
tive and negative inputs to the adder 50 on lines 57 and 
58 are produced from the selector circuitry 51. 

The output from the adder 50 is applied to either or 
both the RAM Y register 40 and the accumulator 52 via 
lines 59. All of the operations of the adder 50 and its 
input selector 51, etc., are controlled by a data path 
control PLA 60 which is responsive to the instruction 
word on lines 33 from the ROM. Control outputs 61 
from the control PLA 60 are indicated by dotted lines. 
The four-bit output from the accumulator can be ap¬ 
plied via lines 53 to an accumulator output buffer 62 and 
thus to a segment decoder 63 for output from the sys¬ 
tem. The segment decoder 63 is a programmable logic 
array like that disclosed in the Ser. No. 163,565, and 
produces up to eight segment outputs on lines 64 which 
are applied to a set of eight output buffers 65. The out¬ 
put arrangement contains memory in the buffer 62 so 
that an output data can be held for more than one ma¬ 
chine cycle. Output is under control of the data control 
logic PLA 60 which is responsive to the instruction 
word on lines 33 from the ROM. 

A status logic circuit 66 provides the function of 
examining for carry or compare from the adder 50, and 
determining whether to branch or call. To this end, 
inputs from the adder 50 via lines 67, and input from the 
control PLA 60 via lines 61 are provided. The status 
logic 66 includes a latch which produces an output 69 to 
the output buffer register 62; this can be decoded out via 
segment decode 62 in many different ways. In the video 
game system, it is used as the most significant bit of a 
5-bit data bus which is transferred out of the Si~S 5 lines 
17. 

A control circuit 70 determines what and when data 
is written into or stored in the RAM 25 via input/output 
control 31 and lines 30. This RAM write control 70 
receives inputs from either the accumulator 52 via lines 
53 or the CKB logic 56 via lines 55, and this circuit 
produces an output on lines 71 which go to the RAM 
I/O circuit 31. Selection of what is written into the 
RAM is made by the instruction word on lines 33, via 
the data path control PLA 60 and command lines 61. 
An important feature of the system is that constants or 
keyboard information, from CKB logic 56, as well as 
the adder output via the accumulator, may be written 
into the RAM, via the write control 70, and further the 
CKB logic 56 can be used to control the setting and 
resetting of bits in the RAM, via the write control 70. 



The RAM page address into which data is written is 
determined by two bits of the instruction word on lines 
33, as applied via lines 72 to a RAM page address regis¬ 
ter 73 and thus to lines 28 which select the RAM page. 
The RAM word or Y address is, of course, selected by 5 
the contents of RAM Y register 40, select circuit 39 and 
decoder 27. 

The four keyboard inputs 16 appear on lines 75, from 
which an input to the CKB logic 56 is provided. In 
normal operation, a keyboard input goes via CKB logic 1° 
56 to the accumulator 52 or RAM Y register 40, from 
whence it is examined by software or ROM program¬ 
ming. In manufacture of the chips, a test mode is possi¬ 
ble, where the keyboard input on line 75 can be entered 
directly into the ROM page buffer address register 46, ^ 
as will be explained. Also, during hardware clear using 
the KC input, the K lines can be entered into the page 
address register, or a K line can be used as an interrupt, 
in non-calculator applications. 

Also included within the processor 15 is a clock oscil- 20 
lator and generator 80 which generates internally a 
basic clock frequency of about 500 kHz or less, and 
from this, produces five clocks 01 to 05 used throughout 
the system. A powerup-clear circuit 82 produces con¬ 
trols which clear the calculator when the power is 25 
turned on. This may be also supplemented by the KC 
input with an external capacitor. 

The outputs 18 from processor 15, used for keyboard 
and joystick scanning, are generated from the RAM 3Q 
word address on lines 26 by an output register 84 which J 
is loaded under control of lines 61 as addressed by RAM 
word lines 26. The output from the register 84 is con¬ 
nected via lines 85 to a set of output buffers 86. Sixteen 
outputs are possible, but only eleven are provided as 35 
outputs from the TMS 1100. 

it is important that the register 84 is a random access 
register, where all bits are separately, independently, 
and mutually exclusively addressed. In this embodi¬ 
ment, only thirteen stages are provided in the register 40 
84, so only the first thirteen of the sixteen address lines 
26 are used. When one of the thirteen bits in the register 
84 is addressed from decoder 27, this bit may be either 
set or reset as determined by controls 61 from the con¬ 
trol PLA, i.e., from the current instruction word. The 45 
bit will remain set or reset until again specifically ad¬ 
dressed and changed; meanwhile, any or all of the other 
bits may be addressed and set or reset in any order. 
Thus, it is possible to have any combination of D regis¬ 
ter bits either set or reset, providing 2 11 or 2048 code 50 
combinations on the output lines 18. During power up 
or hardware clear, all the bits of the register 84 are 
unconditionally reset. 

Similar to the register 84, the other output register 62 
is static in that the contents once entered will remain 55 
until intentionally altered. The output register 62 func¬ 
tions as an output data buffer while the accumulator 52 
and status latch 66 are being manipulated to form the 
next output. The output register 84 is a similar buffer for 
outputting the contents of the Y register 40, but has the 60 
additional feature of being fully random access. The 
data sources for the Y register 40 are the following: a 
four-bit constant stored in ROM 24 as part of an instruc¬ 
tion word; the accumulator 52 transferred to the Y 
register 40 via the selector 51 and adder 50; and data 65 
directly from the RAM 25. Once data is in the Y regis¬ 
ter 40, it can be manipulated by additional instructions 
such as increment or decrement. 
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Referring again to FIGS. 2 a and 26, the data, which 
is output from microcomputer IS via selected ones of 
the segment output terminals (Si-S 8 ) 17 are coupled by 
means of buffer drivers 117 to address registers 118 and 
to the data input terminals of main color and character 
display random access memory (RAM) 120 and set 
table RAM memory 126. Buffer drivers 117 are shown 
in detail in FIG. la, and the horizontal and vertical 
address registers 118 are shown in detail in FIG. 8. As 
illustrated in FIG. 8, address register 118 is comprised 
of two SN54/74LS174 integrated register circuits 118a 
and 1186. 

MEMORY ORGANIZATION 

in order to best understand the memory organization, 
which comprises a novel feature of the video game 
system, reference is here made to FIGS. 15a-15e. Refer¬ 
ring to FIG. 15a, the display 11a of television set 11 has 
a 3:4 aspect ratio, and is, therefore, organized as a 32 
horizontal by 24 vertical matrix. Each square within the 
“display” matrix is, itself, composed of an 8-by-8 “char¬ 
acter” matrix. The characters are any patterns which 
can be drawn on an 8-by-8 grid as exemplified in FIG. 
156. If a single random acess memory were to be pro¬ 
vided to store a total 8-by-8 character, its color and the 
background color for each character in the display 
matrix, a memory on the order of 150K bits would be 
required. By utilizing, instead, the novel memory orga¬ 
nization embodied in the present video game system, 
the memory required to provide the 768 8-by-8 charac¬ 
ters to fill the display is reduced to less than 8K bits of 
random access memory. 

In the present system, main random access memory 
120 is loaded by microcomputer 15 with a display pro¬ 
gram. Random access memory 120 is IK by 8; the IK is 
organized as 32 by 32 with 32 by 24 8-bit words repre¬ 
senting the 32 horizontal and 24 vertical squares of the 
display matrix and the remaining 32-by-8 8-bit words 
utilized as working storage registers. Thus, correspond¬ 
ing to each square in the display matrix is an 8-bit word 
in random access memory 120. This 8-bit memory word 
is partitioned into two 4-bit bytes as illustrated in FIG. 
15c. There are 32 character sets with 16 characters in 
each set. The lower-order byte of the memory word in 
random access memory 120 selects one of 16 characters 
of a character set in ROM character generator 127. The 
higher-order byte points to a table contained in random 
access color and character set memory 126. Memory 
126 is organized as a 16-by 8-bit word memory. Each 
word in the table contained in memory 126 contains 
color and character set information. Thus, as shown in 
FIG. 15c, the high-order 3-bit byte indicates to compos¬ 
ite video generator 129 the color of the character, and 
background color register 142 indicates the background 
color for the character. The lower-order byte of each 
8-bit memory word of memory 126 is five bits, and is 
utilized to address the one of 32 character sets of char¬ 
acter generator ROM 127. Three bits from vertical 
counter 137 are used to complete the address of charac¬ 
ter generator ROM 137 by selecting which line of the 
character is to be read from ROM 127; thus, for each 
character to be displayed, 8 lines will be separately read, 
each line containing eight horizontal squares of “char¬ 
acter” information. 

With the above character addressing scheme, 32 
character sets of 16 characters each, a total of 512 differ¬ 
ent characters can be addressed and selectively dis¬ 
played in the 768 “display” matrix squares. 128 8-by-16 
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characters are stored in one lK-by-8 character genera¬ 
tor ROM, and additional ROM’s may be added to in¬ 
crease the character set. The entire 24-by-32-by-64 TV 
screen grid is defined by a lK-by-8 random access mem¬ 
ory 120. The colors defined by the 3-bit byte from the 5 
table contained in memory 126 are defined in TABLE I 
below. 

TABLE I 


3-BIT RESULTANT 

COLOR CODE CHARACTER COLOR 


R 

B 

G 


0 

0 

0 

BLACK 

0 

0 

1 

GREEN 

0 

1 

0 

BLUE 

0 

1 

1 

CYAN 

1 

0 

0 

RED 

1 

0 

1 

YELLOW 

1 

1 

0 

MAGENTA 

1 

1 

1 

WHITE 


Now that the memory organization has been de¬ 
scribed in terms of data flow, reference is again made to 20 
FIGS. 2 a and 26 so that the memory organization in 
terms of the presently-implemented hardware embodi¬ 
ment is best understood. 

When data is to be stored in address registers 118, the 
two control lines from microcomputer 15 are used to 25 
clock the data on the data bus into the respective ad¬ 
dress registers 118a and 1186. The address stored in 
address register 118 is then utilized to addressing a stor¬ 
age location of RAM 120 (or as will later be discussed 
RAM 126). Address multiplexer 119, shown in detail in 30 
FIG. 8, selects between the address contained in address 
registers 118 and a counter value determined by the 
count contained in horizontal and vertical counters 135 
and 137. Address multiplexer circuitry 119 is comprised 
of three SN54/74Lsl57 integrated selector circuits con- 35 
nected as shown in FIG. 8. 

The display/program RAM 120 is comprised of four 
TMS4050 integrated random access memory circuits 
120a-129d as shown in FIG. 8. When information is 
being stored in random access memory 120, address 40 
multiplexer 119 enables the address contained in address 
register 118 to address RAM 120. The same addressing 
procedure occurs when information is being read from 
RAM 120 to be utilized by microcomputer 15. When¬ 
ever information is being read from RAM 120 to be 45 
displayed, address multiplexer 119 selects the horizontal 
and vertical counters 135 and 137 to provide the proper 
memory address; counters 13 and 137 provide the infor¬ 
mation as to the location containing the display data 
which needs to be displayed at that particular point in 50 
time. 

In writing data into RAM 120 with the address stored 
in address register 118, the data is provided to the data 
input terminals of RAM 120 by microcomputer 15 via 
buffer drivers 117 and 122. Three control lines from 55 
microcomputer 15 to memory timing circuit 140 are 
used to generate control signals for the RAM 120 to 
write the information present on the data bus from 
buffer drivers 117 into the location indicated by the 
contents of address register 118. Memory timing circuit 60 
140 is illustrated in detail in FIG. 116. If microcomputer 
15 requires the retrieval of information that is contained 
in RAM 120 (note that an 8 by 32 word section of RAM 
120 is utilized as working storage space), the address 
register is set to the desired location of RAM 120 as 65 
indicated above, but the control signals going from 
microcomputer 15 to memory timing circuit 140 would 
indicate that the information is to be read from the 


180 

12 

RAM rather than being written into the RAM 120. In 
this case, data from RAM 120 is read and stored in 
multiplex register 121 as previously described with 
respect to the description of FIG. 5. The data contained 
in multiplex register 121 may then be selected by mi¬ 
crocomputer 15 via data multiplexer 100. Data multi¬ 
plexer 100, which is controlled by two control lines 
from microcomputer 15, would then make the data as 
stored in register 121 available on keyboard input termi¬ 
nals 16 of microcomputer 15. 

As previously discussed, 32 by 24 8-bit word registers 
of IK by 8 RAM 120 store the data to be displayed on 
the screen of television set 10 as such data is generated 
by microcomputer 15. The information is stored in 
memory 120 as character set information: the characters 
themselves are not stored but generated in linear (hori¬ 
zontal) sections just prior to being displayed. The four 
least significant bits of the eight-bit word defines one of 
16 characters of a character set, and the four most sig¬ 
nificant bits point to a location in a table, the table being 
contained in 16 by 8 RAM 126. As illustrated in FIG. 
76, RAM 126 is comprised of a pair of SN54/7489 inte¬ 
grated circuit RAMs 126a and 1266. RAM 126 is ad¬ 
dressed by either an address (A0-A3) applied to selec¬ 
tor circuit 125 by address register 118a or an address 
(M0-M3) derived from RAM 120 via bus drivers 122 
which is stored in register 123. Address multiplexer 125 
selects which of the two addresses is to address RAM 
126. A0-A3 is selected in writing the table and M0-M3 
is selected in reading characters in the display cycle. As 
illustrated in FIGS. 7 a and 76, register 123 is comprised 
of an SN54/74LS174 integrated circuit register and 
address multiplexer 125 is comprised of an 
SN54/74LS157 integrated selector circuit. 

As previously discussed, RAM 126 contains color 
and character set information. The three most signifi¬ 
cant bits of each of the 8-bit words in RAM 126 indicate 
the color of the character; while the 5 lower-order bits 
define one of 32 character sets. By utilizing these five 
lower-order bits plus the four lower-order bits derived 
from RAM 120 which are stored in register 124, one of 
the 512 possible characters are selected from ROM 
character generator 127. Microcomputer 15 loads RAM 
126 in a similar manner to the loading of RAM 120. The 
address is set in address register 118a and the data is put 
on the data bus via buffer drivers 117. A control signal 
provided to write control logic 141 causes the informa¬ 
tion on the data bus to be stored in the addressed loca¬ 
tion of RAM 126. Write control logic 141 which is 
comprised of a plurality of logic gates is illustrated in 
detail in FIG. 76. 

When information is being displayed, horizontal and 
vertical counters 135 and 137 keep track of the position 
on the display at which the information is to be dis¬ 
played. Lower-order bits of horizontal couner 135 are 
decoded and used for memory timing. The higher-order 
bits are decoded and used both for horizontal sync 
timing and as part of the address to RAM 120. The 
vertical counter 137 lower-order bits are used as an 
address to the character ROM where the upper bits are 
decoded and used to generate vertical sync and also as 
the vertical address for RAM 120. 

The three high-order bits output by RAM 126 go to 
the composite video generator 129 which is illustrated 
in detail in FIGS. 13a and 136 to provide character 
color while, as previously indicated, the lower five bits 
go to the character generator 127 to select the character 
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set. The address word from the character ROM 127 is 
read out in eight bits and loaded into a SN54/74LS166 
integrated shift register circuit 128 which is illustrated 
in FIG. la. The character data is then shifted out of shift 
register 128, serially (SR), into composite video genera- 5 
tor 129. Also applied to composite video generator 129 
is background color information provided by back¬ 
ground color register 142 which is comprised of an 
SN54/74LS174 register as shown in FIG. 14. 

Horizontal counter 135 is illustrated in detail in FIG. 10 
11c and vertical counter 137 is illustrated in detail in 
FIG. 13. Lower-order bits of horizontal counter 135 are 
decoded and used for memory timing via memory tim¬ 
ing circuit 140 which is illustrated in detail in FIG. life 
Horizontal and vertical counters 135 and 137 are driven 15 
by 11.33-mHz oscillator 134 which is illustrated in detail 
in FIG. 10. 

The higher-order bits of horizontal counter 135 are 
decoded and used by horizontal sync timing circuit 136 
which is illustrated in detail in FIG. 12 and are used as 20 
part of the address to RAM 120. The three lower-order 
bits from vertical counter 137 are used to address char¬ 
acter ROM 127 and the higher-order bits of counter 137 
are decoded and used by vertical sync timing circuit 
138, which circuit is illustrated in detail in FIG. 13, to 25 
generate the vertical sync, and are also used as the verti¬ 
cal address for display RAM 120 as previously dis¬ 
cussed. 

The horizontal timing which is generated by horizon¬ 
tal sync timing circuitry 136 provides the color burst 30 
gate signal to composite video generator 129. Other 
horizontal sync timing signals are provided by timing 
circuit 136 to the composite blanking, and sync genera¬ 
tor 139 which is illustrated in FIG. 13. The horizontal 
blanking, and sync signals are combined with the verti- 35 
cal timing signals from vertical timing sync generator 
138 to provide the composite blanking and sync signals 
which are applied to composite video generator 129 as 
illustrated in FIGS. 9 a and 9b. 

Utilizing the input video from shift register 128, the 40 
composite blanking signals from composite blanking 
and sync generator 139 and the other timing signals 
provided by memory timing circuit 140 and horizontal 
sync timing generator 136, composite video generator 
129 produces a video signal. A 3.579-mHz crystal oscil- 45 
lator circuit 130, which is illustrated in detail in FIG. 9b, 
is utilized to generate the color burst reference signal. 

This signal is then phase shifted to produce six different 
reference signals, one for each of the colors of Table I. 

The composite video signal provided by generator 50 
129 is applied to an RF modulator 131 which modulates 
the composite video signal onto an RF carrier. The RF 
modulated signal from modulator 131 is applied to RF 
antenna switch 132 which is generally used to connect 
a video game to the antenna terminals of a TV set. 55 
Switch 132 is utilized to switch between the antenna 
and the video game. 
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EXAMPLE OF A VIDEO GAME SEQUENCE 

“Doodle” is an example of a game played utilizing the 60 
above described video game system. One of the joystick 
controls 13a is used in this game to control the location 
of a cursor on the display screen of television set 10 and 
keyboard 14a is used to control the color of the cursor 
such that when selected ones of the keys of keyboard 65 
14a are activated, the color of the cursor changes. The 
indicated color then remains as a colorace on the 
screen. 


A cartridge 87 containing a microcomputer with the 
“Doodle” game is inserted in slot 88. Periodically, dur¬ 
ing a pass through the main video game determining 
program stored in the ROM 24 of the microcomputer 
15 contained in the cartridge 87, the program branches 
to a subroutine which is used to scan keyboard 14a, and 
read the states thereof into keyboard input terminals 16 
via data multiplexer circuit 100. The program then 
interrupts to store the data received at terminals 16 into 
the microcomputer accumulator 52 and the key de¬ 
coded. Once microcomputer 15 has decoded which one 
of the keys is depressed it proceeds to a routine which 
will, in the present example, change the color of the 
character on the screen by writing into internal RAM 
25. This information will record flags that directly re¬ 
late to the color desired to be displayed on the screen. 

At this point, microcomputer 15 is ready to receive 
input signals from joystick 13a. In accordance with a 
novel feature of the present game system, movement of 
joystick control 13a from the center position in any 
direction indicates only the “direction” in which the 
cursor is to move; unlike prior art video game systems, 
joystick movement does not relate to the “position” of 
the cursor on the screen. Thus, moving the joystick 
control 13a does not move the cursor to a correspond¬ 
ing position on the screen; instead, joystick control 13a 
indicates the direction of movement, and the movement 
proceeds in that direction automatically until the joy¬ 
stick is returned to the central vertical “0” position. 

The degree of movement of the joystick control 13a 
from the central vertical “0” position indicates the rela¬ 
tive speed that the cursor will move in the selected 
direction. 

Thus, two digital signals are received in sequence by 
microcomputer 15 at keyboard inputs 16; the first being 
the digital joystick X axis code, and the second being 
the digital joystick Y axis code which together indicate 
the exact X-Y coordinates of the digital joystick to 
microcomputer 15. Detecting a value which relates to 
motion of the cursor, for example, a value of +4 for the 
digital joystick X axis and a value +6 for the digital 
joystick Y axis, the cursor proceeds to move along the 
directional vector (4, 6) at a relative speed of +5. If the 
values of the digital joysticks were +2 for the X axis, 
and + 3 for the Y axis, the cursor would move along the 
same directional vector at a speed of +2.5, for example. 

Using the inputs from digital joystick control 13a 
microcomputer 15 computes the position and symbol 
which is to be written on the display screen of television 
10. Microcomputer 15 then writes this information into 
RAM 120 according to the flags which microcomputer 
15 has stored in its internal memory 25. RAM 120 is 
then addressed under control of microcomputer 15 and 
the above described timing circuitry to provide the 
desired image on the display screen. 

Various embodiments of the invention have now 
been described in detail. Since it is obvious that many 
additional changes and modifications can be made in the 
above-described details without departing from the 
nature and spirit of the invention, it is understood that 
the invention is not to be limited to said details except as 
set forth in the appended claims. 

What is claimed is: 

1. A digital joystick control interface system compris¬ 
ing: 

(a) at least one digital joystick control having a shaft 
member which is moveable in any direction in an 
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X-Y plane to selected points in said plane, said 
joystick control including: 

(i) first and second sets of switch means controlled 

by said shaft member, said first set of switch 
means for generating a digital-coded signal rep- 5 
resentative of the X coordinate of said shaft 
member in said X-Y plane, and said second set of 
switches for generating a digital-coded signal 
representative of the Y coordinate of said shaft 
member in said X-Y plane, 10 

(ii) means coupling one terminal of each switch in 
said first set to a first common terminal, and 

(iii) means coupling a second terminal of each switch 
in said second set to a second common terminal; 

(b) a digital processor having a plurality of input 15 
terminals and a plurality of output terminals; 

(c) a common data bus having a plurality of conduc¬ 
tors respectively coupled to the input terminals of 
said digital processor; 

(d) a first set of P-N junction devices respectively 20 
coupling second terminals of each switch in said 
first set to a respective conductor of said common 
data bus; 

(e) a second set of P-N junction devices respectively 
coupling second terminals of each switch in said 25 
second set to a respective conductor of said data 
bus in common with said first set; 

(f) means coupling said first common terminal to a 
first output terminal of said digital processor; and 

(g) means coupling said second common terminal to a 30 
second output terminal of said digital processor; 
and 

(h) said digital processor including means for selec¬ 
tively strobing said first and second output termi¬ 
nals whereby the X and Y coordinate data is sepa- 35 
rately received at the input terminals of said digit 
processor via said common data bus. 

2. The interface system according to claim 1 includ¬ 
ing: 

(a) a keyboard matrix having first and second sets of 40 
terminals wherein closure of a key of said keyboard 
completes a conductive path between a terminal of 
said first set and a terminal of said second set; 

(b) means coupling said first set of terminals of said 
keyboard to other output terminals of said digital 45 
processor; and 

(c) a plurality of P-N junction devices coupling re¬ 

spective ones of said second set of terminals of said 
keyboard to respective conductors of said common 
data bus in common with said first and second sets 50 
of switches, said digital processor including means 
for selectively strobing said other output terminals 
wherein keyboard information is selectively re¬ 
ceived at said input terminals via said common data 
bus. 55 

3. The interface system according to claim 1 includ¬ 
ing a video display device coupled to further output 
terminals of said digital processor wherein the image 
generated by said video display device is controlled by 
said digital processor in accordance with the relative X 60 
and Y coordinates of said shaft member as received 
over said common data bus. 

4. The interface system according to claim 2, wherein 

said digital joystick and keyboard are located in a re¬ 
mote unit from said digital processor. 65 

5. The interface system according to claim 2 includ¬ 
ing pull-up resistor means coupling said common data 
bus conductors to said digital processor means to cause 


said conductors to go to a “high” logic level wherein a 
strobe signal on the output terminal of said digital pro¬ 
cessor transmitted via a switch of one of said first or 
second sets or said keyboard causes the respective line 
of said data bus to go to a “low” logic level. 

6. A digital joystick control interface system compris- 
ing: 

(a) first and second remote control units each includ¬ 
ing: 

(i) a digital joystick control having a shaft member 
which is moveable in any direction in an X-Y 
plane to selected points in said plane, said joy¬ 
stick control including first and second sets of 
switch means controlled by said shaft member, 
said first set of switch means for generating a 
digital-coded signal representative of the X coor¬ 
dinate of said shaft member in said X-Y plane, 
and said second set of switches for generating a 
digital-coded signal representative of the Y coor¬ 
dinate of said shaft member in said X-Y plane, 
means coupling one terminal of each switch in 
said first set to a first common terminal, and 
means coupling a second terminal of each switch 
in said second set to a second common terminal, 

(ii) a common data bus having a plurality of con¬ 
ductors, 

(iii) a first set of P-N junction devices respectively 
coupling second terminals of each switch in said 
first set to a respective conductor of said com¬ 
mon data bus; 

(iv) a second set of P-N junction devices respectively 
coupling second terminals of each switch in said 
second set to a respective conductor of said data 
bus in common with said first set; 

(b) a digital processor having a plurality of input 
terminals and a plurality of output terminals; 

(c) a multiplexer circuit controllably coupling the 
common data busses of said first and second remote 
control units to the input terminals of said digital 
processor; 

(d) means coupling said first common terminals of 
each of said joystick controls to a first output ter¬ 
minal of said digital processor; and 

(e) means coupling said second common terminals of 
each of said joystick controls to a second output 
terminal of said digital processor; and 

(f) said digital processor including means for selec¬ 
tively strobing said first and second output termi¬ 
nals and for selectively controlling said multiplexer 
circuit whereby the X and Y coordinate data of 
each of said remote control units is separately re¬ 
ceived at the input terminals of said digital proces¬ 
sor. 

7. The interface system according to claim 6, wherein 
each of said remote control units further includes a 
keyboard matrix having first and second sets of termi¬ 
nals wherein closure of a key of said keyboard comletes 
a conductive path between a terminal of said first set 
and a terminal of said second set; and a plurality of P-N 
junction devices coupling respective ones of said sec¬ 
ond set of terminals of said keyboard to respective con¬ 
ductors of said common data bus of the respective re-, 
mote control unit in common with said first and second 
sets of switches thereof, wherein means is provide cou¬ 
pling the first set of terminals of said keyboard to other 
output terminals of said digital processor, said digital 
processors include means for selectively strobing said 
other output terminals wherein keyboard information is 



4 , 142,180 


17 

selectively received at said input terminals via said mul¬ 
tiplexer circuit. 

8. The interface system according to claim 6 includ¬ 
ing a video display device coupled to further output 
terminals of said digital processor wherein the image 5 
generated by said video display device is controlled by 
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said digital processor in accordance with the relative X 
and Y coordinates of the joystick controls of each of 
said remote control units as received via said multi¬ 
plexer circuit. 

***** 
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